home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
CU Amiga Super CD-ROM 11
/
CU Amiga Magazine's Super CD-ROM 11 (1997)(EMAP Images)(GB)(Track 1 of 3)[!][issue 1997-06].iso
/
cucd
/
programming
/
oberonv4
/
source
/
system
/
strings.mod
(
.txt
)
< prev
next >
Wrap
Oberon Text
|
1996-01-22
|
5KB
|
142 lines
Syntax10.Scn.Fnt
FoldElems
Syntax10i.Scn.Fnt
Documentation
StampElems
Alloc
11 Dec 95
Syntax10b.Scn.Fnt
Syntax8i.Scn.Fnt
(*-------------------------------------------------------------
Strings provides a set of operations on strings (i.e., on string constants and character
arrays, both of which contain the character 0X as a terminator). All positions in
strings start at 0.
Strings.Length(s)
returns the number of characters in s up to and excluding the first 0X.
Strings.Insert(src, pos, dst)
inserts the string src into the string dst at position pos (0 <= pos <= Length(dst)).
If pos = Length(dst), src is appended to dst. If the size of dst is not large enough
to hold the result of the operation, the result is truncated so that dst is always
terminated with a 0X.
Strings.Append(s, dst)
has the same effect as Insert(s, Length(s), dst).
Strings.Delete(s, pos, n)
deletes n characters from s starting at position pos (0 <= pos < Length(s)).
If n > Length(s) - pos, the new length of s is pos.
Strings.Replace(src, pos, dst)
has the same effect as Delete(dst, pos, Length(src)) followed by an Insert(src, pos, dst).
Strings.Extract(src, pos, n, dst)
extracts a substring dst with n characters from position pos (0 <= pos < Length(src)) in src.
If n > Length(src) - pos, dst is only the part of src from pos to Length(src) - 1. If the size of
dst is not large enough to hold the result of the operation, the result is truncated so that
dst is always terminated with a 0X.
Strings.Pos(pat, s, pos)
returns the position of the first occurrence of pat in s after position pos (inclusive).
If pat is not found, -1 is returned.
Strings.Cap(s)
replaces each lower case letter in s by its upper case equivalent.
-------------------------------------------------------------*)
MODULE Strings; (*HM 94-06-22 /
PROCEDURE Length* (s: ARRAY OF CHAR): INTEGER;
VAR i: INTEGER;
BEGIN
i := 0; WHILE (i < LEN(s)) & (s[i] # 0X) DO INC(i) END ;
RETURN i
END Length;
PROCEDURE Append* (extra: ARRAY OF CHAR; VAR dest: ARRAY OF CHAR);
VAR n1, n2, i: INTEGER;
BEGIN
n1 := Length(dest); n2 := Length(extra); i := 0;
WHILE (i < n2) & (i + n1 < LEN(dest)) DO dest[i + n1] := extra[i]; INC(i) END ;
IF i + n1 < LEN(dest) THEN dest[i + n1] := 0X END
END Append;
PROCEDURE Insert* (source: ARRAY OF CHAR; pos: INTEGER; VAR dest: ARRAY OF CHAR);
VAR n1, n2, i: INTEGER;
BEGIN
n1 := Length(dest); n2 := Length(source);
IF pos < 0 THEN pos := 0 END ;
IF pos > n1 THEN Append(dest, source); RETURN END ;
IF pos + n2 < LEN(dest) THEN (*make room for source*)
i := n1; (*move also 0X if it is there*)
WHILE i >= pos DO
IF i + n2 < LEN(dest) THEN dest[i + n2] := dest[i] END ;
DEC(i)
END
END ;
i := 0; WHILE i < n2 DO dest[pos + i] := source[i]; INC(i) END
END Insert;
PROCEDURE Delete* (VAR s: ARRAY OF CHAR; pos, n: INTEGER);
VAR len, i: INTEGER;
BEGIN
len:=Length(s);
IF pos < 0 THEN pos:=0 ELSIF pos >= len THEN RETURN END ;
IF pos + n < len THEN
i:=pos + n; WHILE i < len DO s[i - n]:=s[i]; INC(i) END ;
IF i - n < LEN(s) THEN s[i - n]:=0X END
ELSE s[pos]:=0X
END Delete;
PROCEDURE Replace* (source: ARRAY OF CHAR; pos: INTEGER; VAR dest: ARRAY OF CHAR);
BEGIN
Delete(dest, pos, pos + Length(source));
Insert(source, pos, dest)
END Replace;
PROCEDURE Extract* (source: ARRAY OF CHAR; pos, n: INTEGER; VAR dest: ARRAY OF CHAR);
VAR len, destLen, i: INTEGER;
BEGIN
len := Length(source); destLen := SHORT(LEN(dest)) - 1;
IF pos < 0 THEN pos := 0 END ;
IF pos >= len THEN dest[0] := 0X; RETURN END ;
i := 0;
WHILE (pos + i <= LEN(source)) & (source[pos + i] # 0X) & (i < n) DO
IF i < destLen THEN dest[i] := source[pos + i] END ;
INC(i)
END ;
dest[i] := 0X
END Extract;
PROCEDURE Pos* (pattern, s: ARRAY OF CHAR; pos: INTEGER): INTEGER;
VAR n1, n2, i, j: INTEGER;
BEGIN
n1 := Length(s); n2 := Length(pattern);
IF n2 = 0 THEN RETURN 0 END ;
i := pos;
WHILE i <= n1 - n2 DO
IF s[i] = pattern[0] THEN
j := 1; WHILE (j < n2) & (s[i + j] = pattern[j]) DO INC(j) END ;
IF j = n2 THEN RETURN i END
END ;
INC(i)
END ;
RETURN -1
END Pos;
PROCEDURE Cap* (VAR s: ARRAY OF CHAR);
VAR i: INTEGER;
BEGIN
i := 0;
WHILE s[i] # 0X DO
IF ("a" <= s[i]) & (s[i] <= "z") THEN s[i] := CAP(s[i]) END ;
INC(i)
END Cap;
PROCEDURE Match* (string, pattern: ARRAY OF CHAR): BOOLEAN;
PROCEDURE M (VAR name, mask: ARRAY OF CHAR; n, m: INTEGER): BOOLEAN;
BEGIN
WHILE (n >= 0) & (m >= 0) & (mask[m] # "*") DO
IF name[n] # mask[m] THEN RETURN FALSE END ;
DEC(n); DEC(m)
END ;
(* ----- name empty | mask empty | mask ends with "*" *)
IF m < 0 THEN RETURN n < 0 END ;
(* ----- name empty | mask ends with "*" *)
WHILE (m >= 0) & (mask[m] = "*") DO DEC(m) END ;
IF m < 0 THEN RETURN TRUE END ;
(* ----- name empty | mask still to be matched *)
WHILE n >= 0 DO
IF M(name, mask, n, m) THEN RETURN TRUE END ;
DEC(n)
END ;
RETURN FALSE
END M;
BEGIN
RETURN M(string, pattern, Length(string)-1, Length(pattern)-1)
END Match;
END Strings.